前言
在日常开发中,或许程序产生的日志不会那么大,但是在生产环境中,在日积月累下,日志只会越来越大,当有一天生产环境报错,需要排查错误的时候,这个庞大的日志数据仅仅是打开它就会让人懵逼了,于是我们需要将日志进行切割保存,便于我们后期的使用
本文使用的方法仅仅针对Windows服务器,且方法不止这一种,还有其他的办法,我这里就不写出来了,至于Linux系统服务器上的nginx日志切割方法不在本文内容中
创建nginxLog.bat文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| @echo off rem @echo off rem 取1天之前的日期 echo wscript.echo dateadd("d",-1,date) >%tmp%\tmp.vbs for /f "tokens=1,2,3* delims=/" %%i in ('cscript /nologo %tmp%\tmp.vbs') do set y=%%i for /f "tokens=1,2,3* delims=/" %%i in ('cscript /nologo %tmp%\tmp.vbs') do set m=%%j for /f "tokens=1,2,3* delims=/" %%i in ('cscript /nologo %tmp%\tmp.vbs') do set d=%%k if %m% LSS 9 set m=0%m% if %d% LSS 9 set d=0%d% echo %y%-%m%-%d% rem 设置 Nginx 位于的盘符 set NGINX_DRIVER=C: rem 设置 Nginx 的主目录 set NGINX_PATH=%NGINX_DRIVER%\nginx-1.14.1 rem 设置 Nginx 的日志目录 set LOG_PATH=%NGINX_PATH%\logs rem 移动文件 move %LOG_PATH%\access.log %LOG_PATH%\access_%y%-%m%-%d%.log move %LOG_PATH%\error.log %LOG_PATH%\error_%y%-%m%-%d%.log rem 切换到 Nginx 所在的盘符 %NGINX_DRIVER% rem 进入 Nginx 的主目录 cd %NGINX_PATH% rem 向 nginx 发送 reopen 信号以重新打开日志文件,功能与 Linux 平台中的 kill -USR1 一致 nginx -s reopen echo on
|
将该文件放在服务器相应的位置,然后在Windows服务器上将其添加到计划任务里面,设置为每天执行一次就可以了(仅仅针对Windows服务器)
结语
习惯了写一个结尾,不过本文也没啥结尾的,nginx的日至切割方法还有其他的,比如直接在config文件上添加脚本……